奥义思网站建设-www.aooly.com
奥义思坚信质量高于产量
我们的团队自成立以来,秉承着质量是衡量价值最重要标准的理念,致力于打造高品质数字产品。不放过任何一个小的瑕疵而一蹴而就,体现的不仅是我们对品质的苛求,也是对客户以及产品负责的态度。
马上联系我们,让天才的设计师帮您实现这一切。

    asp.net 2.0下嵌套masterpage页的可视化编辑

      相信大家都用过asp.net 2.0下的嵌套的masterpage功能,该功能很强大,可以让用户先制作出模版页后,然后很容易地套用到其他页面中去。而且模版页还可以嵌套的,但嵌套后的模版页,我们会发觉有一个问题,那就是当使用嵌套的模版页后,在设计视图状态下,是没办法对其进行可视化操作的,那么如何解决这个问题呢?我找了下老外的blog,找到了老外提供的一个方法,暂且可以绕个弯来解决该问题,下面讲解一下:

      我们可以写一个基类,叫basepage.cs,放在app_code目录下,在这个类中,添加一个叫runtimeMasterPageFile的属性,是一个字符串类型,指定在运行期间才用哪一个模版文件,并且重写OnPreInit方法,代码如下:


         public class BasePage : System.Web.UI.Page
      {
          private string runtimeMasterPageFile; 
          public string RuntimeMasterPageFile
          {
              get
              {
                  return runtimeMasterPageFile;
              }
              set
              {
                  runtimeMasterPageFile = value;
              }
          }

          protected override void OnPreInit(EventArgs e)
          {
              if (runtimeMasterPageFile != null)
              {
                  this.MasterPageFile = runtimeMasterPageFile;
              }
          
              base.OnPreInit(e);
          }
      }

      接着,我们构造一个叫mainmaster.master的模版页,里面随便搞一个header和footer的信息,中间留一个叫MainContent的contentplaceholder,然后再建一个叫submaster.master的模版页,其中的MasterPageFile="~/MainMaster.master",以套用mainmaster模版页,其中放一个一行两列的表格,如下:


       <asp:Content ID="foo" ContentPlaceHolderId="MainContent" runat="server">

          <table>
              <tr>
                  <td width="300">
                  
                      Left Column in SubMaster
                      <br />
                  
                      <asp:ContentPlaceHolder ID="LeftColumn" runat="server">
                      </asp:ContentPlaceHolder>
                  </td>
                  <td>
                 
                      Right Column in SubMaster
                      <br />            
                  
                      <asp:ContentPlaceHolder ID="RightColumn" runat="server">
                      </asp:ContentPlaceHolder>
                  </td>
              </tr>
          
          </table>
      </asp:Content>

      最后,在一个aspx页面中,这样指定


       <%@ Page Language="C#" MasterPageFile="" RuntimeMasterPageFile="SubMaster.master" CodeFileBaseClass="BasePage" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" Title="Untitled Page" %>

      可以看到,在这里,我们不设置masyterpage的属性,而是指定了RuntimeMasterPageFile的属性为submaster.master,这个是在运行时候才加载的模版,而codefilebaseclass属性指定了我们刚才写的那个类basepage.cs,这样,我们就可以在这个ASPX的设计视图状态下看到拉,可以拖拉设计了。

      要注意的是,根据微软的说法,听说要到下一个版本的VISUAL STUDIO,才能完全支持模版嵌套时的完全设计